<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title></title>
    <style type="text/css">
        #box1 {
            width: 100px;
            height: 100px;
            background-color: red;
            position: absolute;
        }


    </style>

    <script type="text/javascript">

        /**
         * 06.定时练习-处理移动div问题
         * 问题:移动时卡顿
         * 解决:
         *    1.使用定时器来控制移动的速度
         *    2.使用方向键控制移动的方向
         */

        window.onload = function () {
            //定义一个变量，来表示移动的速度
            var speed = 10;

            //创建一个变量表示方向
            //通过修改dir来影响移动的方向
            var dir = 0;

            //控制div移动速度,开启一个定时器,每隔30ms,来控制div的移动
            setInterval(function () {
                /*
                 * 37 左
                 * 38 上
                 * 39 右
                 * 40 下
                 */
                switch (dir) {
                    case 37:
                        //alert("向左"); left值减小
                        box1.style.left = box1.offsetLeft - speed + "px";
                        break;
                    case 39:
                        //alert("向右"); offset left （左偏移）
                        box1.style.left = box1.offsetLeft + speed + "px";
                        break;
                    case 38:
                        //alert("向上");
                        box1.style.top = box1.offsetTop - speed + "px";
                        break;
                    case 40:
                        //alert("向下");
                        box1.style.top = box1.offsetTop + speed + "px";
                        break;
                }
            }, 30);


            //控制div移动方向,为document绑定一个按键按下的事件
            document.onkeydown = function (event) {
                //获取事件对象,兼容不同浏览器获取事件对象的方式。
                event = event || window.event;
                //当用户按了ctrl以后，速度加快
                if (event.ctrlKey) {
                    speed = 50;
                } else {
                    speed = 10;
                }
                //使dir等于按键的值
                dir = event.keyCode;
            };

            //当按键松开时，div不再移动
            document.onkeyup = function () {
                //设置方向为0
                dir = 0;
            };
        };

    </script>
</head>
<body>
<div id="box1"></div>
</body>
</html>
